C语言中嵌入式SQL语句 |
您所在的位置:网站首页 › 嵌入式sql语言 例题 › C语言中嵌入式SQL语句 |
实验内容: 掌握SQL Server 2000的预编译程序NSQLPREP.EXE的使用(以课本例题1进行调试); 实验步骤: 一、数据库环境配置 1、创建xuesheng数据库,建立student表等; 2、关闭sql server 2000服务管理器; 3、将devtools文件夹拷贝到:C:\Program Files\Microsoft SQL Server 4、将Binn文件夹拷贝到:C:\Program Files\Microsoft SQL Server\MSSQL 5、启动服务器; 二、VC++6.0编辑器配置(初始化Vc++环境) 1.工具—>选择—>目录—>Include Files 添加: C:\Program Files\Microsoft SQL Server\devtools\include 并设为第一项 2.选择Library Files 添加:C:\Program Files\Microsoft SQL Server\devtools\x86lib 并设为第一项 三、写程序,预编译,最后在VC++中编译、执行 1、编辑EXEC.sqc文件,保存到:C:\Program Files\Microsoft SQL Server\MSSQL\Binn目录 EXEC.sqc文件如下: // EXEC.cpp : Defines the entry point for the console application.// #include #include EXEC SQL BEGIN DECLARE SECTION; /*主变量说明开始*/ char deptname[64];char HSno[64];char HSname[64]; char HSsex[64];int HSage;intNEWAGE; long SQLCODE;EXEC SQL END DECLARE SECTION; /*主变量说明结束*/ EXEC SQL INCLUDE sqlca; /*定义SQL通信区*/ /*************************************************************************/ int main(void) /*C语言主程序开始*/{int count = 0;char yn; /*变量yn代表yes或no*/printf("Please choose the department name(CS/MA/IS): "); scanf("%s", deptname); /*为主变量deptname赋值*/EXEC SQL CONNECT TO demin USER sa; /*连接数据库TEST*/EXEC SQL DECLARE SX CURSOR FOR /*定义游标*/SELECT Sno, Sname, Ssex, Sage /*SX对应语句的执行结果*/FROM StudentWHERE SDept = :deptname;EXEC SQL OPEN SX; /*打开游标SX便指向查询结果的第一行*/ for ( ; ; ) /*用循环结构逐条处理结果集中的记录*/{ EXEC SQL FETCH SX INTO :HSno, :HSname, :HSsex,:HSage; /*推进游标,将当前数据放入主变量*/if (sqlca->sqlcode != 0) /* sqlcode != 0,表示操作不成功*/break; /*利用SQLCA中的状态信息决定何时退出循环*/if(count++ == 0) /*如果是第一行的话,先打出行头*/printf("\n%-10s %-20s %-10s %-10s\n", "Sno", "Sname", "Ssex", "Sage");printf("%-10s %-20s %-10s %-10d\n", HSno, HSname, HSsex, HSage); /*打印查询结果*/printf("UPDATE AGE(y/n)?"); /*询问用户是否要更新该学生的年龄*/do{ scanf("%c",&yn);}while(yn != 'N' && yn != 'n' && yn != 'Y' && yn != 'y');if (yn == 'y' || yn == 'Y') /*如果选择更新操作*/{ printf("INPUT NEW AGE:"); scanf("%d",&NEWAGE); /*用户输入新年龄到主变量中*/ EXEC SQL UPDATE Student /*嵌入式SQL*/SET Sage = :NEWAGEWHERE CURRENT OF SX ;} /*对当前游标指向的学生年龄进行更新*/} EXEC SQL CLOSE SX; /*关闭游标SX不再和查询结果对应*/EXEC SQL COMMIT WORK; /*提交更新*/EXEC SQL DISCONNECT TEST; /*断开数据库连接*/} 2、使用MS-DOS进行预编译: 1)进到Binn文件下:cd C:\Program Files\Microsoft SQL Server\MSSQL\Binn 2)调用预编译程序nsqlprep.exe程序:nsqlprep EXEC 成功编译完成结果: 见附件1 3、使用Vc++进行编译,见附件2 4、添加库文件:工程—>设置—>Link—>对象/库模块 输入SQLakw32.lib Caw32.lib两个文件名。附件3 注意,两个文件之间用空格分开。 5 、将动态链接库SQLakw32.dll,sqlaiw32.dll文件拷贝到操作系统目录下的子目录C:\WINDOWS\system32中6、连接:附件4 7、执行:附件5 附件1: 附件2(VC编译EXEC.C) 附件3(配置添加库文件) 附件4(连接) |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |